# -*- coding: utf-8 -*-
from datetime import timedelta
from time import time

from utils.alerts.doris_telnet_check import net_is_used
from utils.operators.rich_sql_sensor import RichSqlSensor
# from jms.dm.dm_shipno_weight_detail_new_dt import jms_dm__dm_shipno_weight_detail_new_dt

label = f"dm_shipno_weight_detail_new_{int(time())}"
timeout = timedelta(hours=2).seconds
dorisConn = net_is_used()
doris_jms_dm__dm_shipno_weight_detail_new = RichSqlSensor(
    task_id='doris_jms_dm__dm_shipno_weight_detail_new',
    pool='broker_load_pool',
    email=['jarl.huang@jtexpress.com','yl_bigdata@yl-scm.com'],
    task_concurrency=1,
    conn_id='new_doris',
    pre_sql=f"""
                 TRUNCATE TABLE jms_dm.dm_shipno_weight_detail_new PARTITION (
                    p{{{{ execution_date | cst_ds_nodash }}}}, 
                    p{{{{ execution_date | date_add(-1) | cst_ds_nodash }}}}, 
                    p{{{{ execution_date | date_add(-2) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-3) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-4) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-5) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-6) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-7) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-8) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-9) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-10) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-11) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-12) | cst_ds_nodash }}}},
                    p{{{{ execution_date | date_add(-13) | cst_ds_nodash }}}}
                );
                LOAD LABEL jms_dm.{label} (
                DATA INFILE(
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-13) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-12) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-11) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-10) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-9) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-8) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-7) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-6) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-5) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-4) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-3) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-2) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(-1) | cst_ds }}}}/*",
                    "hdfs://{{{{var.value.hadoop_namespace}}}}/dw/hive/jms_dm.db/external/dm_shipno_weight_detail_new_dt/dt={{{{ execution_date | date_add(0) | cst_ds }}}}/*"
                )
                INTO TABLE dm_shipno_weight_detail_new
                FORMAT AS 'PARQUET'
                )
                WITH BROKER '{{{{ var.json.doris_brokers | random_choice }}}}'
                PROPERTIES ('timeout'='{timeout}', 'max_filter_ratio'='0.0')""",
    poke_sql=f"SHOW LOAD FROM jms_dm WHERE label = '{label}' ORDER BY CreateTime DESC LIMIT 1",
    sql_on_kill=f"CANCEL LOAD FROM jms_dm WHERE LABEL = '{label}'",
    success=lambda r: r[2] == 'FINISHED',
    failure=lambda r: (r[2] is not None and r[2] == 'CANCELLED', str(r[7])),
    poke_interval=60,
    execution_timeout=timedelta(seconds=timeout + 120))

# doris_jms_dm__dm_shipno_weight_detail_new << [
#     jms_dm__dm_shipno_weight_detail_new_dt
# ]
